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Foreword 



rd , 



This Technical Specification has been produced by the 3 Generation Partnership Project (3GPP). 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 

where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 



Introduction 



rd , 



The present document is part of a TS-family covering the 3 Generation Partnership Project: Technical Specification 
Group Services and System Aspects; Telecommunication management; as identified below: 

32.601: "Configuration Management (CM); Basic CM Integration Reference Point (IRP); Requirements" 

32.602: "Configuration Management (CM); Basic CM Integration Reference Point (IRP); Information 

Service (IS)" 

32.603: "Configuration Management (CM); Basic CM Integration Reference Point (IRP); Common 

Object Request Broker Architecture (CORBA) Solution Set (SS)" 

32.607: "Configuration Management (CM); Basic CM Integration Reference Point (IRP); SOAP Solution 

Set (SS)" 

Configuration Management (CM), in general, provides the operator with the ability to assure correct and effective 
operation of the 3G network as it evolves. CM actions have the objective to control and monitor the actual configuration 
on the Network Elements (NEs) and Network Resources (NRs), and they may be initiated by the operator or by 
functions in the Operations Systems (OSs) or NEs. 

CM actions may be requested as part of an implementation programme (e.g. additions and deletions), as part of an 
optimisation programme (e.g. modifications), and to maintain the overall Quality of Service (QoS). The CM actions are 
initiated either as single actions on single NEs of the 3G network, or as part of a complex procedure involving actions 
on many resources/objects in one or several NEs. 
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Scope 



The purpose of this Basic Configuration Management (CM) IRP: CORBA Solution Set is to define the mapping of the 
Basic CM IRP: IS (see 3GPP TS 32.602 [4]) to the protocol specific details necessary for implementation of this IRP in 
a CORBA/IDL environment. 

This document defines NRM independent data types and methods. 

This Solution Set specification is related to 3G TS 32.602 V7.0.X. 



References 



The following documents contain provisions which, through reference in this text, constitute provisions of the present 
document. 

• References are either specific (identified by date of publication, edition number, version number, etc.) or 
non-specific. 

• For a specific reference, subsequent revisions do not apply. 

• For a non-specific reference, the latest version applies. In the case of a reference to a 3GPP document (including 
a GSM document), a non-specific reference implicitly refers to the latest version of that document in the same 
Release as the present document. 

[I] 3GPP TS 32.101: "Telecommunication management; Principles and high level requirements". 

[2] 3GPP TS 32.102: "Telecommunication management; Architecture". 

[3] 3GPP TS 32.600: "Telecommunication management; Configuration Management (CM); Concept 

and high-level requirements". 

[4] 3GPP TS 32.602: "Telecommunication management; Configuration Management (CM); Basic CM 

Integration Reference Point (IRP) Information Service (IS)". 

[5] 3GPP TS 32.300: "Telecommunication management; Configuration Management (CM); Name 

convention for Managed Objects". 

[6] OMG Notification Service, Version 1 .0. 

[7] OMG CORBA services: Common Object Services Specification, Update: November 22, 1996. 

[8] The Common Object Request Broker: Architecture and Specification (for specification of valid 

version, see [1]). 

[9] 3GPP TS 32.303: "Telecommunication management; Configuration Management (CM); 

Notification Integration Reference Point (IRP); Common Object Request Broker Architecture 
(CORBA) Solution Set (SS)". 

[10] 3GPP TS 32.312: "Telecommunication management; Generic Integration Reference Point (IRP) 

management; Information Service (IS)". 

[II] 3GPP TS 32.663: "Telecommunication management; Configuration Management (CM); Kernel 
CM Integration Reference Point (IRP); Common Object Request Broker Architecture (CORBA) 
Solution Set (SS)". 
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Definitions and abbreviations 



3.1 Definitions 

For terms and definitions please refer to 3GPP TS 32.101 [1], 3GPP TS 32.102 [2], 3GPP TS 32.600 [3] and 
3GPPTS 32.602 [4]. 

3.2 Abbreviations 

For the purposes of the present document, the following abbreviations apply: 

CORBA Common Object Request Broker Architecture 

DN Distinguished Name 

IS Information Service 

IDL Interface Definition Language (OMG) 

IRP Integration Reference Point 

MO Managed Object 

MOC Managed Object Class 

NRM Network Resource Model 

OMG Object Management Group 

SS Solution Set 



4 IRP document version number string 

The IRP document version number (sometimes called "IRPVersion" or "SS version number") string is used to identify 
this specification. The string is derived using a rule described in 3GPP TS 32.312: [10]. 

This string (or sequence of strings, if more than one version is supported) is returned in getBasicCmlRPVersion 
method. 



Architectural features 



The overall architectural feature of Basic Configuration Management IRP is specified in 3GPP TS 32.602 [4]. 
This clause specifies features that are specific to the CORBA SS. 

5.1 Filter language 

The filter language used in the SS is the Extended Trader Constraint Language (see OMG Notification Service [6]). 
IRP Agents may throw a FilterComplexityLimit exception when a given filter is too complex. However, for 3GPP 
Release 99 an "empty filter" shall be used i.e. a filter that satisfies all MOs of a scoped search (this does not affect the 
filter for notifications as defined in the Notification IRP - see 3GPP TS 32.303 [9]). 

5.2 Syntax for Distinguished Names and Versions 

The format of a Distinguished Name is defined in 3GPP TS 32.300 [5]. 
The version of this IRP is represented as a string (see also clause 4). 
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6 Mapping 

6.1 General mappings 

The IS parameter name managedObjectlnstance is mapped into DN. 

Attributes modelling associations as defined in the NRM (here also called "reference attributes") are in this SS mapped 
to attributes. The names of the reference attributes in the NRM are mapped to the corresponding attribute names in the 
MOC. When the cardinality for an association is 0..1 or 1..1 the datatype for the reference attribute is defined as an 
MOReference. The value of an MO reference contains the distinguished name of the associated MO. When the 
cardinality for an association allows more than one referred MO, the reference attribute will be of type 
MOReferenceSet, which contains a sequence of MO references. 

If a reference attribute is changed, an Attribute ValueChange notification (see TS 32.663 [11]) is emitted. 



6.2 Operation mapping 



The Basic CM IRP: IS (see 3GPP TS 32.602 [4]) defines semantics of operation visible across the Basic Configuration 
Management IRP. Table 1 indicates mapping of these operations to their equivalents defined in this SS. 

Table 1 : Mapping from IS Operation to SS equivalents 



IS Operation 
(3GPP TS 32.602 [4]) 


SS Method 


Qualifier 


getMoAttributes 


BasicCmlrpOperations::find_managed_objects 
BasicCmlnformationlterator::next_basic_cm_informations 


M 


getContainment 


BasicCmlrpOperations::find_managed_objects 
BasicCmlnformationlterator::next_basic_cm_informations 





getlRPVersion (see note) 


get_basic_cm_irp_version 


M 


cancelOperation 


BasicCmlnformationlterator::destroy 





createMo 


BasicCmlrpOperations::create_managed_object 





deleteMo 


BasicCmlrpOperations::delete_managed_objects 

DeleteResultlterator::next_basic_cm_informations 

DeleteResultlterator::next_delete_errors 





setMoAttributes 


BasicCmlrpOperations::modify_managed_objects 
l\/lodifyResultlterator::next_basic_cm_informations 
l\/lodifyResultlterator::next_modification_errors 





getOperationProfile (see 
note) 


get_basic_cm_irp_operation_profile 





getNotificationProfile (see 
note) 


get_basic_cm_irp_notification_profile 





NOTE: This operation is of IOC IVIanagedGenericIRP specified in [10]. The IOC BasicCmIRP of [4] inherits from it. 



6.3 Operation parameter mapping 



The Basic CM IRP: IS (see 3GPP TS 32.602 [4]) defines semantics of parameters carried in operations across the Basic 
Configuration Management IRP. Tables 2 through 8 indicate the mapping of these parameters, as per operation, to their 
equivalents defined in this SS. 

The SS operation find_managed_objects is equivalent to the IS operation getMoAttributes when called with 
ResultContents set to NAMES_AND_ATTRIBUTES. Iterating the BasicCmlnformationlterator is used to fetch the 
result. 
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Table 2: Mapping from IS getMoAttributes parameters to SS equivalents 



IS Operation parameter 


SS Method parameter 


Qualifier 


invokeldentifier 


- (No equivalence) 


- 


invokeldentifierOut 


Return value of type BasicCmlnformationlterator 


M 


baseObjectlnstance 


DN base_object 


M 


scope 


SearchControl search_control (SearchControl.type and 
SearchControl. level) 


M 


filter 


SearchControl search_control (SearchControl.filter) 


M 


attributeListIn 


AttributeNameSet requested_attributes 


M 


managedObjectClass 

managedObjectlnstance 

attributeListOut 


Return value of type BasicCmlnformationlterator - parameter out 
ResultSet fetched_elements of method next_basic_cm_informations 


M 


status 


Exceptions: 

FindManagedObjects, 

ManagedGenericlRPSystem::lnvalidParameter, 

UndefinedMOException, 

lllegalDNFormatException, 

UndefinedScopeException, 

lllegalScopeTypeException, 

lllegalScopeLevelException, 

lllegalFilterFormatException, 

FilterComplexityLimit 


M 



The SS operation find_managed_objects is equivalent to the IS operation getContainment when called with 
ResultContents set to NAMES. Iterating the BasicCmlnformationlterator is used to fetch the result. 

Table 3: Mapping from IS getContainment parameters to SS equivalents 



IS Operation parameter 


SS IVIethod parameter 


Qualifier 


invokeldentifier 


- (No equivalence) 


- 


invokeldentifierOut 


Return value of type BasicCmlnformationlterator 


M 


baseObjectlnstance 


DN base_object 


M 


scope 


SearchControl search_control (SearchControl.type and SearchControl. level) 





Not specified in IS 


SearchControl search_control (SearchControl.filter) 


M 


containment 


Return value of type BasicCmlnformationlterator - parameter out ResultSet 
fetched_elements of method next_basic_cm_informations 


M 


status 


Exceptions: 

FindManagedObjects, 

ManagedGenericlRPSystem::OperationNotSupported, 

ManagedGenericlRPSystem::ParameterNotSupported, 

ManagedGenericlRPSystem::lnvalidParameter, 

ManagedGenericlRPSystem::ValueNotSupported, 

UndefinedMOException, 

lllegalDNFormatException, 

UndefinedScopeException, 

lllegalScopeTypeException, 

lllegalScopeLevelException, 

lllegalFilterFormatException, 

FilterComplexityLimit 


M 



Table 4: Mapping from IS getlRPVersion parameters to SS equivalents 



IS Operation parameter 


SS IVIethod parameter 


Qualifier 


versionNumberSet 


Return value of type ManagedGenericlRPConstDefs::VersionNumberSet 


M 


status 


Exceptions: 
GetBasicCmlRPVersion 


M 



£75/ 



3GPP TS 32.603 version 8.0.0 Release 8 



ETSI TS 132 603 V8.0.0 (2009-01) 



Table 5: Mapping from IS cancelOperation parameters to SS equivalents 



IS Operation parameter 


SS IVIethod parameter 


Qualifier 


invokeldentifier 


- (Not applicable, the BasicCmlnformationlterator instance identifies the ongoing 
operation) 


M 


status 


Exceptions: 

ManagedGenericlRPSystem::OperationNotSupported, 

DestroyException 


M 



Table 6: Mapping from IS createMo parameters to SS equivalents 



IS Operation parameter 


SS Method parameter 


Qualifier 


managedObjectClass 
managedObjectlnstance 


DN object_name 


M 


referenceObjectI nstance 


DN reference_object 





attributeListIn 
attributeListOut 


IVIoAttributeSet attributes 


M 


status 


AttributeErrorSeq attribute_errors 

Exceptions: 

CreateManagedObject, 

IVIanagedGenericlRPSystem::OperationNotSupported, 

IVIanagedGenericlRPSystem::ParameterNotSupported, 

ManagedGenericlRPSystem::lnvalidParameter, 

UndefinedMOException, 

lllegalDNFormatException, 

DuplicatelVIO, 

CreateNotAI lowed, 

ObjectClasslVlismatch, 

NoSuchObjectClass, 

ParentObjectDoesNotExist 


M 



Table 7: Mapping from IS deleteMo parameters to SS equivalents 



IS Operation parameter 


SS Method parameter 


Qualifier 


baseObjectI nstance 


DN base_object 


M 


scope 


SearchControl search_control (SearchControl.type and SearchControl. level) 


M 


filter 


SearchControl search_control (SearchControl.filter) 


M 


deletionList 


Return value of type DeleteResultlterator - parameter out ResultSet 
fetched_elements of method next_basic_cm_informations 


M 


status 


Return value of type DeleteResultlterator - parameter out DeleteErrorSeq 

fetched_delete_errors of method next_delete_errors 

Exceptions: 

DeleteManagedObjects, 

ManagedGenericlRPSystem::OperationNotSupported, 

ManagedGenericlRPSystem::lnvalidParameter, 

UndefinedlVloException, 

lllegalDNFormatException, 

UndefinedScopeException, 

lllegalScopeTypeException, 

lllegalScopeLevelException, 

Illegal FilterFormatException, 

FilterComplexityLimit 


M 
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Table 8: Mapping from IS setMoAttributes parameters to SS equivalents 



IS Operation parameter 


SS Method parameter 


Qualifier 


baseObjectlnstance 


DN base_object 


IVI 


scope 


SearchControl searcli_control (SearchControl.type and SearchControl. level) 


M 


filter 


SearchControl searcli_control (SearchControl.filter) 


IVI 


modificationList 


AttributeModificationSet modifications 


M 


modification ListOut 


Return value of type ModifyResultlterator - parameter out ResultSet 
fetclied_elements of method next_basic_cm_informations 


M 


status 


Return value of type ModifyResultlterator - parameter out 

IVIodifyAttributeErrorsSeq fetched_modify_errors of method 

next_modify_errors 

Exceptions: 

IVIodifylVlanagedObjects, 

ManagedGenericlRPSystem::OperationNotSupported, 

ManagedGenericlRPSystem::lnvalidParameter, 

UndefinedlVloException, 

lllegalDNFormatException, 

UndefinedScopeException, 

lllegalScopelypeException, 

lllegalScopeLevelException, 

Illegal Pi IterFormatException, 

FilterComplexityLimit 


M 



Table 9: Mapping from IS getOperationProfile parameters to SS equivalents 



IS Operation parameter 


SS Method parameter 


Qualifier 


irpVersion 


IVIanagedGenericlRPConstDefs::VersionNumber basic_cm_irp_version 


M 


operationNameProfile, 
operationParameterProfile 


Return value of type ManagedGenericlRPGonstDefs::MethodList 


M 


status 


Exceptions: 

GetBasicCmlRPOperationProfile, 

ManagedGenericlRPSystem::OperationNotSupported, 

IVIanagedGenericlRPSystem::lnvalidParameter 


M 



Table 10: Mapping from IS getNotificationProfile parameters to SS equivalents 



IS Operation parameter 


SS Method parameter 


Qualifier 


irpVersion 


ManagedGenericlRPConstDefs::VersionNumber 
basic_cm_irp_version 


M 


notificationNameProfile, 
notificationParameterProfile 


Return value of type ManagedGenericlRPGonstDefs::MethodList 


M 


status 


Exceptions: 

GetBasicGmlRPNotificationProfile, 

ManagedGenericlRPSystem::OperationNotSupported, 

ManagedGenericlRPSystem::lnvalidParameter 


M 



Void 
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Annex A (normative): 
CORBA IDL, Access Protocol 

A.1 IDL specification (file name 
"BasicCMIRPConstDefs.idI") 

//File: BasicCMIRPConstDefs.idI 

iifndef _BASIC_CM_IRP_CONST_DEFS_IDL_ 
#define _BASIC_CM_IRP_CONST_DEFS_IDL_ 

// This statement must appear after all include statements 
#pragma prefix "3gppsa5.org" 

/* ## Module: BasicCMIRPConstDefs 

This module contains commonly used definitions for BasicCMIRP. 

*/ 

module BasicCMIRPConstDefs 

{ 

/** 

* Defines the name of a Managed Object Class 
*/ 

typedef string MOClass; 

/** 

* The format of Distinguished Name (DN) is specified in 3GPP TS 32.300 

* "Name Conventions for Managed Objects". 
*/ 

typedef string DN; 

/** 

* Defines the name of an attribute of a Managed Object 
*/ 

typedef string MOAttributeName; 

/** 

* Defines the value of an attribute of a Managed Object in form of a CORBA 

* Any. Apart from basic datatypes already defined in CORBA, the allowed 

* attribute value types are defined in the AttributeTypes module. 
*/ 

typedef any MOAttributeValue; 

/** 
* 

* In this version the only allowed filter value is "TRUE" i.e. a filter that 

* matches everything. 
V 

typedef string Filter; 

/** 

* ResultContents is used to tell how much information to get back 

* from the f ind_managed_objects operation. 
* 

* NAMES: Used to get only Distinguished Name 

* for MOs . 

* The name contains both the MO class 

* and the names of all superior objects in the naming 

* tree. 
* 

* NAMES_AND_ATTRIBUTES : Used to get both NAMES plus 

* MO attributes {all or selected) . 
*/ 

enum ResultContents 

{ 

NAMES, 

NAMES AND ATTRIBUTES 



/** 
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* ScopeType defines the kind of scope to use in a search 

* together with SearchControl . level, in a SearchControl value. 
* 

* SearchControl . level is always >= . If a level is bigger than the 

* depth of the tree there will be no exceptions thrown. 

* BASE_ONLY: level ignored, just return the base object. 

* BASE_NTH_LEVEL : return all subordinate objects that are on "level" 

* distance from the base object, where is the base object. 

* BASE_SUBTREE : return the base object and all of its subordinates 

* down to and including the nth level. 

* BASE_ALL: level ignored, return the base object and all of it's 

* subordinates . 
*/ 

enum ScopeType 

{ 

BASE_ONLY, 
BASE_NTH_LEVEL , 
BASE_SUBTREE, 
BASE_ALL 

}; 
/** 

* SearchControl controls the f ind_managed_object search, 

* and contains : 

* the type of scope {"type" field), 

* the level of scope {"level" field) , level means the "baseObject" , 

* level 1 means baseobject including its sub-ordinates etc.. 

* the filter ("filter" field), 

* the result type {"contents" field) . 

* The type, level and contents fields are all mandatory. 

* The filter field contains the filter expression. 

* The string "TRUE" indicates "no filter", 

* i.e. a filter that matches everything. 
*/ 

struct SearchControl 

{ 

ScopeType type; 
unsigned long level; 
Filter filter_; 
ResultContents contents; 

}; 
/** 

* Represents an attribute: "name" is the attribute name 

* and "value" is the attribute value. 
*/ 

struct MOAttribute 

{ 

MOAttributeName name; 
MOAttributeValue value; 

}; 

typedef sequence <MOAttribute> MOAttributeSet ; 

struct Result 

{ 

DN mo; 

MOAttributeSet attributes; 

}; 

typedef sequence <Result> ResultSet; 

/** 

* AttributeErrorCategory defines the categories of errors, related to 

* attributes, that can occur during creation or modification of MOs . 
* 

* NO_SUCH_ATTRIBUTE : The specified attribute does not exist. 

* INVALID_ATTRIBUTE_VALUE : The specified attribute value is not valid. 

* MISSING_ATTRIBUTE_VALUE: An attribute value is required but none was 

* provided and no default value is defined for the attribute. 

* INVALID_MODIFY_OPERATOR: The specified modify operator is not valid 

* {e.g. operator ADD_VALUES applied to a non multi-valued attribute 

* or operator SET_TO_DEFAULT applied where no default value is defined) . 

* MODIFY_NOT_ALLOWED: The modification of the attribute is not allowed. 

* MODIFY_FAILED : The modification failed because of an unspecified reason. 
*/ 

enum AttributeErrorCategory 

{ 
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NO_SUCH_ATTRIBUTE , 
INVALID_ATTRIBUTE_VALUE , 
MISSING_ATTRIBUTE_VALUE , 
INVALID_MODIFY_OPERATOR, 
MODI FY_NOT_ALLOWED , 
MODIFY FAILED 



* DeleteErrorCategory defines the categories of errors that can occur 

* during deletion of MOs . 
* 

* SUBORDINATE_OBJECT: The MO cannot be deleted due to subordinate MOs. 

* DELETE_NOT_ALLOWED : The deletion of the MO is not allowed. 

* DELETE_FAILED : The deletion failed because of an unspecified reason. 
*/ 

enum DeleteErrorCategory 

{ 

SUBORDINATE_OBJECT, 
DELETE_NOT_ALLOWED , 
DELETE_FAILED 

}; 
/** 

* AttributeError represents an error, related to an attribute, that occured 

* during creation or modification of MOs. 

* It contains: 

* - the name of the indicted attribute {"name" field) , 

* - the category of the error {"error" field) , 

* - optionally, the indicted attribute value {"value" field), 

* - optionally, additional details on the error {"reason" field) . 
*/ 

struct AttributeError 

{ 

MOAttributeName name; 
AttributeErrorCategory error; 
MOAttributeValue value; 
string reason; 



typedef sequence <AttributeError> AttributeErrorSeq; 

/** 

* DeleteError represents an error that occured during deletion of MOs. 

* It contains: 

* - the distinguished name of the indicted MO { "object_name" field) , 

* - the category of the error {"error" field) , 

* - optionally, additional details on the error {"reason" field) . 
*/ 

struct DeleteError 

{ 

DN object_name; 
DeleteErrorCategory error; 
string reason; 



typedef sequence <DeleteError> DeleteErrorSeq; 

/** 

* ModifyAttributeErrors represents errors that occured during 

* modification of attributes of a MO. 

* It contains: 

* - the distinguished name of the indicted MO { "object_name" field) 

* - a sequence containing the attribute errors {"errors" field) . 
*/ 

struct ModifyAttributeErrors 

{ 

DN object_name; 
AttributeErrorSeq errors; 



typedef sequence <ModifyAttributeErrors> ModifyAttributeErrorsSeq; 
typedef sequence <MOAttributeName> AttributeNameSet ; 

/** 

* ModifyOperator defines the way in which an attribute value is to be 

* applied to an attribute in a modification of MO attributes. 
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* REPLACE: replace the current value with the provided value 

* ADD_VALUES : for a multi-valued attribute, add the provided values to the 

* current list of values 

* REMOVE_VALUES : for a multi-valued attribute, remove the provided values 

* from the current list of values 

* SET_TO_DEFAULT: set the attribute to its default value 
*/ 

enum ModifyOperator 

{ 

REPLACE, 
ADD_VALUES , 
REMOVE_VALUES , 
SET TO DEFAULT 



* AttributeModif ication defines an attribute value and the way it is to 

* be applied to an attribute in a modification of MO attributes. 

* It contains: 

* - the name of the attribute to modify {"name" field) , 

* - the value to apply to this attribute {"value" field) , 

* - the way the attribute value is to be applied to the attribute 

* {"operator" field) . 
V 

struct AttributeModif ication 

{ 

MOAttributeName name; 
MOAttributeValue value ; 
ModifyOperator operator; 



typedef sequence <AttributeModif ication> AttributeModif icationSet; 



#endif // _BASIC_CM_IRP_CONST_DEFS_IDL_ 
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A.2 IDL specification (file name "BasicCIVIIRPSystem.idI") 

//File: BasicCMIRPSystem. idl 
iifndef _BASIC_CM_IRP_SYSTEM_IDL_ 
#define _BASIC_CM_IRP_SYSTEM_IDL_ 

#include <ManagedGenericIRPConstDef s . idl> 
#include <ManagedGenericIRPSystem. idl> 
#include <BasicCMIRPConstDef s . idl> 

// This statement must appear after all include statements 
#pragma prefix "3gppsa5.org" 

module BasicCmlRPSystem 

{ 

exception IllegalFilterFormatException { 
string reason; 

}; 

exception IllegalDNFormatException { 
string reason; 

}; 

exception IllegalScopeTypeException { 
string reason; 

}; 

exception IllegalScopeLevelException { 
string reason; 

}; 

exception Undef inedMOException { 
string reason; 

}; 

exception Undef inedScopeException { 
string reason; 

}; 

exception FilterComplexityLimit { 
string reason; 

}; 

exception DuplicateMO { } ; 

exception CreateNotAllowed { } ; 

exception ObjectClassMismatch {}; 

exception NoSuchObjectClass { 

BasicCMIRPConstDef s : iMOClass objectClass; 

}; 

exception ParentObjectDoesNotExist {}; 

/** 

* System otherwise fails to complete the operation. System can provide 

* reason to qualify the exception. The semantics carried in reason 

* is outside the scope of this IRP. 
*/ 

exception NextBasicCmlnformations { string reason; }; 

exception NextDeleteErrors { string reason; }; 

exception NextModifyErrors { string reason; }; 

exception DestroyException { string reason; }; 

exception GetBasicCmlRPVersion { string reason; }; 

exception GetBasicCmlRPOperationProf ile { string reason; }; 

exception GetBasicCmlRPNotif icationProf ile { string reason; }; 

exception FindManagedObjects { string reason; }; 

exception CreateManagedObject { string reason; }; 

exception DeleteManagedObjects { string reason; }; 

exception ModifyManagedObjects { string reason; }; 

/** 

The BasicCmlnformationlterator is used to iterate through a snapshot of 
Managed Object Information when IRPManager invokes f ind_managed_objects . 
IRPManager uses it to pace the return of Managed Object Information. 

IRPAgent controls the life-cycle of the iterator. However, a destroy 
operation is provided to handle the case where IRPManager wants to stop 
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the iteration procedure before reaching the last iteration. 

*/ 

interface BasicCmInf ormationlterator 

{ 

/** 

This method returns between 1 and "how_many" Managed Object information. 
The IRPAgent may return less than "how_many" items even if there are 
more items to return. "how_many" must be non-zero. Return TRUE if there 
may be more Managed Object information to return. Return FALSE if there 
are no more Managed Object information to be returned. 

If FALSE is returned, the IRPAgent will automatically destroy the 
iterator. 

©parm how_many how many elements to return in the "f etched_elements" out 

parameter. 
Oparm f etched_elements the elements. 
Oreturns A boolean indicating if any elements are returned. 

"f etched_elements" is empty when the BasicCmInf ormationlterator is 

empty . 
*/ 

boolean next_basic_cm_informations { 

in unsigned short how_many, 

out BasicCMIRPConstDef s : iResultSet f etched_elements 
) 
raises { 

NextBasicCmInf ormations , 

ManagedGenericIRPSystem: : InvalidParameter, 

ManagedGenericIRPSystem: lOperationNotSupported) ; 

/** 

This method destroys the iterator. 

*/ 

void destroy {) 

raises { 

DestroyException, 

ManagedGenericIRPSystem: lOperationNotSupported) ; 

} ; // end of BasicCmInf ormationlterator 

/** 

The DeleteResultlterator is used to iterate through the list of deleted MOs 

when IRPManager invokes method "delete_managed_objects" . 

IRPManager uses it to pace the return of Managed Object Information. 

IRPAgent controls the life-cycle of the iterator. However, a destroy 

operation is provided to handle the case where IRPManager wants to stop 

the iteration procedure before reaching the last iteration. 

*/ 

interface DeleteResultlterator : BasicCmInf ormationlterator 

{ 

/** 

Inherited method "next_basic_cm_inf ormations" has the same behaviour as 
for interface BasicCmlnformationlterator, except that: 

- The Managed Object information returned in parameter 

"f etched_elements" contains only the DNs of the deleted MOs 
(no attributes are returned) . 

- If FALSE is returned, the IRPAgent will not automatically destroy the 
iterator. 

*/ 

/** 

This method returns between and "how_many" deletion errors. The 
IRPAgent may return less than "how_many" items even if there are more 
items to return. "how_many" must be non-zero. Return TRUE if there are 
more deletion errors to return. Return FALSE if there are no more 
deletion errors to be returned. 

If FALSE is returned and last call to inherited method 

"next_basic_cm_inf ormations" also returned FALSE {i.e. no more Managed 
Object information to be returned), the IRPAgent will automatically 
destroy the iterator. 

©parm how_many: how many deletion errors to return in the 

"f etched_delete_errors" out parameter, 
©parm f etched_delete_errors : the deletion errors, 
©returns: a boolean indicating if any deletion errors are returned. 
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*/ 

boolean nextdeleteerrors { 

in unsigned short how_many, 

out BasicCMIRPConstDef s : iDeleteErrorSeq f etched_delete_errors 
) 
raises { 

NextDeleteErrors , 

ManagedGenericIRPSystem: : InvalidParameter) ; 

} ; // end of DeleteResultlterator 

/** 

The ModifyResultlterator is used to iterate through the list of modified 
MOs when IRPManager invokes method "modify_managed_objects" . 
IRPManager uses it to pace the return of Managed Object Information. 

IRPAgent controls the life-cycle of the iterator. However, a destroy 

operation is provided to handle the case where IRPManager wants to stop 

the iteration procedure before reaching the last iteration. 

*/ 

interface ModifyResultlterator : BasicCmlnformationlterator 

{ 

/** 

Inherited method "next_basic_cm_informations" has the same behaviour as 
for interface BasicCmlnformationlterator, except that: 

- The Managed Object information returned in parameter 

"f etched_elements" contains DNs and attributes of the modified MOs. 

- If FALSE is returned, the IRPAgent will not automatically destroy the 
iterator. 

*/ 

/** 

This method returns between and "how_many" modification errors. The 
IRPAgent may return less than "how_many" items even if there are more 
items to return. "how_many" must be non-zero. Return TRUE if there are 
more modification errors to return. Return FALSE if there are no more 
modification errors to be returned. 

If FALSE is returned and last call to inherited method 

"next_basic_cm_informations" also returned FALSE {i.e. no more Managed 
Object information to be returned), the IRPAgent will automatically 
destroy the iterator. 

@parm how_many: how many modification errors to return in the 

"f etched_modify_errors" out parameter. 
Oparm f etched_modify_errors : the modification errors. 

Oreturns : a boolean indicating if any modification errors are returned. 
*/ 

boolean nextmodif ication_errors ( 

in unsigned short how_many, 

out BasicCMIRPConstDef s : iModifyAttributeErrorsSeq 
f etched_modify_errors 
) 
raises { 

NextModif yErrors , 

ManagedGenericIRPSystem: : InvalidParameter) ; 

} ; // end of ModifyResultlterator 

/** 

* The BasicCmlrpOperations interface. 

* Supports a number of Resource Model versions. 
*/ 

interface BasicCmlrpOperations 

{ 

* Get the version (s) of the interface 

* ©raises GetBasicCmlRPVersion when the system for some reason 

* can not return the supported versions. 

* ©returns all supported versions. 
*/ 

ManagedGenericIRPConstDef s : : VersionNumberSet get_basic_cm_irp_version { ) 
raises (GetBasicCmlRPVersion) ; 

/** 
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* Return the operation profile for a specific Basic CM IRP version. 

* ©raises GetBasicCmlRPOperationProf ile when the system for some reason 

* cannot return the supported operations and parameters. 

* ©returns the list of all supported operations and their supported 

* parameters for the specified version. 
*/ 

ManagedGenericIRPConstDef s : iMethodList get_basic_cm_irp_operation_prof ile 
{ 

in ManagedGenericIRPConstDef s : iVersionNumber basic_cm_irp_version 
) 
raises { 

GetBasicCmlRPOperationProf ile , 

ManagedGenericIRPSystem: lOperationNot Supported, 

ManagedGenericIRPSystem: : InvalidParameter) ; 

/** 

* Return the notification profile for a specific Basic CM IRP version. 

* ©raises GetBasicCmlRPNotif icationProf ile when the system for some 

* reason cannot return the supported notifications and parameters. 

* ©returns the list of all supported notifications and their supported 

* parameters for the specified version. 
*/ 

ManagedGenericIRPConstDef s : iMethodList 

get_basic_cm_irp_notif ication_prof ile { 

in ManagedGenericIRPConstDef s : iVersionNumber basic_cm_irp_version 
) 
raises { 

GetBasicCmlRPNotif icationProf ile, 

ManagedGenericIRPSystem: lOperationNot Supported, 

ManagedGenericIRPSystem: : InvalidParameter) ; 

/** 

* Performs a containment search, using a SearchControl to 

* control the search and the returned results. 
* 

* All MOs in the scope constitute a set that the filter works on. 

* The result BasicCmlnformationlterator contains all matched MOs, 

* with the amount of detail specified in the SearchControl. 

* For the special case when no managed objects are matched in 

* f ind_managed_objects, the BasicCmlnformationlterator will be returned. 

* Executing the next_basicCmInformations in the 

* BasicCmlnformationlterator will return FALSE for 

* completion. 
* 

* ©parm base_object The start MO in the containment tree. 

* ©parm search_control the SearchControl to use. 

* ©parm requested_attributes defines which attributes to get. 

* If this parameter is empty {"") , all attributes shall 

* be returned. In this version this is the only supported semantics. 

* Note that this argument is only 

* relevant if ResultContents in the search control is 

* specif ed to NAMES_AND_ATTRIBUTES . 
* 

* ©raises ManagedGenericIRPSystem: : ValueNotSupported if a valid but 

* unsupported parameter value is passed. E.g. the contents 

* field in the searchcontrol parameter contains the value NAMES and 

* the optional getContainment IS operation is not supported. 

* ©raises Undef inedMOException The MO does not exist. 

* ©raises IllegalDNFormatException The dn syntax string is 

* malformed. 

* ©raises IllegalScopeTypeException The ScopeType in scope contains 

* an illegal value. 

* ©raises IllegalScopeLevelException The scope level is negative 

* {<0) . 

* ©raises IllegalFilterFormatException The filter string is 

* malformed. 

* ©raises FilterComplexityLimit if the filter syntax is correct, 

* but the filter is too complex to be processed by the IRPAgent . 

* ©see SearchControl 

* ©see BasicCmlnformationlterator 
*/ 

BasicCmlnformationlterator f ind_managed_objects { 



in BasicCMIRPConstDef s 
in BasicCMIRPConstDef s 
in BasicCMIRPConstDef s 
raises { 



DN base_object, 
SearchControl search_control, 
AttributeNameSet requested_attributes) 
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FindManagedObj ects , 



ParameterNotSupported, 
InvalidParameter, 
ValueNotSupported, 
OperationNot Supported, 



ManagedGenericIRPSystem: 
ManagedGenericIRPSystem : 
ManagedGenericIRPSystem : 
ManagedGenericIRPSystem : 
Undef inedMOException, 
I llegalDNFormat Except ion, 
Undef inedScopeExcept ion, 
IllegalScopeTypeException, 
IllegalScopeLevelException, 
I llegalFilterFormat Except ion 
FilterComplexityLimit) ; 



* Performs the creation of a MO instance in the MIB maintained 

* by the IRPAgent . 
* 

* Oparm object_name: the distinguished name of the MO to create. 

* @parm ref erence_object : the distinguished name of a reference MO. 

* Oparm attributes: in input, initial attribute values for the MO to 

* create; in output, actual attribute values of the created MO. 

* Oparm attribute_errors : errors, related to attributes, that caused the 

* creation of the MO to fail. 

* Oraises ManagedGenericIRPSystem: lOperationNotSupported: The operation 

* is not supported. 

* Oraises ManagedGenericIRPSystem: : ParameterNotSupported: An optional 

* parameter is not supported. 

* Oraises ManagedGenericIRPSystem: : InvalidParameter : An invalid 

* parameter value has been provided. 

* Oraises Undef inedMOException: The MO does not exist. 

* Oraises IllegalDNFormatException: The DN syntax string is malformed. 

* Oraises DuplicateMO: A MO already exist with the same DN as the one 

* to create. 

* ©raises CreateNotAllowed: The creation of the MO is not allowed. 

* Oraises ObjectClassMismatch: The object class of the MO to create does 

* not match with the object class of the provided reference MO. 

* Oraises NoSuchObjectClass : The class of the object to create is not 

* recognized. 

* Oraises ParentObjectDoesNotExist : The parent MO instance of the 

* ManagedEntity specified to be created does not exist. 
*/ 

void create_managed_object { 

in BasicCMIRPConstDef s : :DN object_name, 

in BasicCMIRPConstDef s : :DN ref erence_obj ect , 

inout BasicCMIRPConstDef s : :MOAttributeSet attributes, 

out BasicCMIRPConstDef s : :AttributeErrorSeq attribute_errors 
) 
raises { 

CreateManagedOb j ect , 

ManagedGenericIRPSystem : 

ManagedGenericIRPSystem : 

ManagedGenericIRPSystem : 

Undef inedMOException, 

IllegalDNFormatException, 

DuplicateMO, 

CreateNotAllowed, 

Obj ectClassMismatch, 

NoSuchOb j ectClass , 

ParentObjectDoesNotExist) ; 

/** 

* Performs the deletion of one or more MO instances from the MIB 

* maintained by the IRPAgent, using a SearchControl to control the 

* instances to be deleted. 
* 

* All MOs in the scope constitute a set that the filter works on. 

* All matched MOs will be deleted by this operation. 

* The returned DeleteResultlterator is used to retrieve the DNs of the 

* MOs deleted and the errors that may have occurred preventing deletion 

* of some MOs . 

* For the special case when no managed objects are matched in 

* delete_managed_objects, the DeleteResultlterator will be returned. 

* Executing the next_basicCmInformations in the DeleteResultlterator 

* will return FALSE for completion. 
* 

* Oparm base_object: the start MO in the containment tree. 

* Oparm search control: the SearchControl to use; field "contents" has no 



OperationNot Supported, 
ParameterNotSupported, 
InvalidParameter, 



£75/ 



3GPP TS 32.603 version 8.0.0 Release 8 20 ETSI TS 1 32 603 V8.0.0 (2009-01 ) 

* meaning here and shall be ignored. 

* ©returns: a DeleteResultlterator {see above) . 
* 

* ©raises ManagedGenericIRPSystem: lOperationNotSupported: The operation 

* is not supported. 

* ©raises ManagedGenericIRPSystem: : InvalidParameter: An invalid 

* parameter value has been provided. 

* ©raises Undef inedMOExceptiom The MO does not exist. 

* ©raises IllegalDNFormatExceptiom The DN syntax string is malformed. 

* ©raises IllegalScopeTypeException: The ScopeType in scope contains 

* an illegal value. 

* ©raises IllegalScopeLevelExceptiom The scope level is negative {<0) . 

* ©raises IllegalFilterFormatException: The filter string is malformed. 

* ©raises FilterComplexityLimit : The filter syntax is correct, 

* but the filter is too complex to be processed by the IRPAgent . 
*/ 

DeleteResultlterator delete_managed_objects { 

in BasicCMIRPConstDef s : :DN base_object, 

in BasicCMIRPConstDef s :: SearchControl search_control 
) 
raises { 

DeleteManagedOb j ects , 

ManagedGenericIRPSystem: :OperationNot Supported, 

ManagedGenericIRPSystem: : InvalidParameter, 

Undef inedMOExcept ion, 

I llegalDNFormat Except ion, 

Undef inedScopeExcept ion, 

IllegalScopeTypeException, 

IllegalScopeLevelException, 

IllegalFilterFormatException, 

FilterComplexityLimit) ; 

/** 

* Performs the modification of MO attributes. One or more MOs attributes 

* may be modified according to a SearchControl. 
* 

* All MOs in the scope constitute a set that the filter works on. 

* All matched MOs will have their attributes modified by this operation. 

* The returned ModifyResultlterator is used to retrieve the DNs of the 

* modified MOs together with the values of the modified attributes, and 

* the errors that may have occurred preventing modification of some 

* attributes. 

* For the special case when no managed objects are matched in 

* modify_managed_objects, the ModifyResultlterator will be returned. 

* Executing the next_basicCmInf ormations in the ModifyResultlterator 

* will return FALSE for completion. 
* 

* ©parm base_object: the start MO in the containment tree. 

* ©parm search_control : the SearchControl to use; field "contents" has no 

* meaning here and shall be ignored. 

* ©parm modifications: the values for the attributes to modify and 

* the way those values are to be applied to the attributes. 

* ©returns: a ModifyResultlterator {see above) . 
* 

* ©raises ManagedGenericIRPSystem: :OperationNotSupported: The operation 

* is not supported 

* ©raises ManagedGenericIRPSystem: : InvalidParameter : An invalid 

* parameter value has been provided 

* ©raises Undef inedMOException: The MO does not exist. 

* ©raises IllegalDNFormatException: The DN syntax string is malformed. 

* ©raises IllegalScopeTypeException: The ScopeType in scope contains 

* an illegal value. 

* ©raises IllegalScopeLevelException: The scope level is negative {<0) . 

* ©raises IllegalFilterFormatException: The filter string is malformed. 

* ©raises FilterComplexityLimit: The filter syntax is correct, 

* but the filter is too complex to be processed by the IRPAgent. 
*/ 

ModifyResultlterator modify_managed_objects { 

in BasicCMIRPConstDef s : :DN base_object, 

in BasicCMIRPConstDef s :: SearchControl search_control, 

in BasicCMIRPConstDef s : :AttributeModificationSet modifications 
) 
raises { 

Modif yManagedOb j ects , 

ManagedGenericIRPSystem: :OperationNot Supported, 

ManagedGenericIRPSystem: : InvalidParameter, 

Undef inedMOException, 

IllegalDNFormatException, 
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Undef inedScopeException, 
IllegalScopeTypeException, 
IllegalScopeLevelException, 
I llegalFilterFormat Except ion, 
FilterComplexityLimit) ; 



#endif // _BASIC_CM_IRP_SYSTEM_IDL_ 
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